给代码块pre标签增加一个“复制代码”按钮

您所在的位置:网站首页 html 复制按钮 给代码块pre标签增加一个“复制代码”按钮

给代码块pre标签增加一个“复制代码”按钮

2023-06-29 01:21| 来源: 网络整理| 查看: 265

给代码块pre标签增加一个“复制代码”按钮 2020-02-25 16:10 JavaScript 阅3668

写文章的时候,作为一名专业的码农,经常会在文章中粘贴一些代码。有的时候代码块比较长,在后期使用中需要复制这段代码就比较麻烦。参考其他比较专业的博客系统,都在代码块上有一个复制代码的按钮。用来快速复制整个代码块的代码。于是我也想给我的博客增加一个这个功能。

注:chrome测试通过。其他浏览器未进行测试。

实现思路:1、在页面加载完成之后,使用js给每个pre标签增加一个按钮“复制代码”2、给按钮增加点击事件,点击事件的功能就是复制代码块的内容

代码部分:css部分,btn-pre-copy是pre标签中使用js增加的“复制代码”按钮。css的作用是让他显示在pre标签的右上角。这里要注意pre标签和按钮中position属性

.content pre{ position: relative; background-color: #f5f5f5; border: 1px solid #ccc; border-radius: 4px; padding: 10px; } pre .btn-pre-copy{ -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; -khtml-user-select: none; user-select: none; position: absolute; top: 10px; right: 12px; font-size: 12px; line-height: 1; cursor: pointer; color: hsla(0,0%,54.9%,.8); transition: color .1s; }

js部分,js部分主要是给pre标签增加按钮和实现拷贝部分,我这里拷贝部分的实现是先实例化一个临时的节点textarea,然后吧pre的内容设置进这个临时节点,然后选中内容进行复制,最后销毁这个节点。具体参考代码。js部分有依赖于jquery

$(function(){ //给每一串代码元素增加复制代码节点 let preList = $(".content pre"); for (let pre of preList) { //给每个代码块增加上“复制代码”按钮 let btn = $("复制代码"); btn.prependTo(pre); } }); //执行复制代码操作 function preCopy(obj) { //执行复制 let btn = $(obj); let pre = btn.parent(); //为了实现复制功能。新增一个临时的textarea节点。使用他来复制内容 let temp = $(""); //避免复制内容时把按钮文字也复制进去。先临时置空 btn.text(""); temp.text(pre.text()); temp.appendTo(pre); temp.select(); document.execCommand("Copy"); temp.remove(); //修改按钮名 btn.text("复制成功"); //一定时间后吧按钮名改回来 setTimeout(()=> { btn.text("复制代码"); },1500); }

这里在gitee上做了一个简单的demo。demo示例:

完整代码:https://gitee.com/lqccan/blog-demo/tree/master/%E5%89%8D%E7%AB%AF/%E5%A4%8D%E5%88%B6%E4%BB%A3%E7%A0%81

觉得内容还不错?打赏个钢镚鼓励鼓励!!👍



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3